[INFO] cloning repository https://github.com/fpcMotif/ebook-renamer
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/fpcMotif/ebook-renamer" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FfpcMotif%2Febook-renamer", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FfpcMotif%2Febook-renamer'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 1fab0f15c9108cb84e71c70609883f4cc2967a5c
[INFO] testing fpcMotif/ebook-renamer against try#b8e88e5ddf5521a9f43ee3f62a702388c713e4bb for pr-155114
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FfpcMotif%2Febook-renamer" "/workspace/builds/worker-1-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/fpcMotif/ebook-renamer
[INFO] finished tweaking git repo https://github.com/fpcMotif/ebook-renamer
[INFO] tweaked toml for git repo https://github.com/fpcMotif/ebook-renamer written to /workspace/builds/worker-1-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/fpcMotif/ebook-renamer on toolchain b8e88e5ddf5521a9f43ee3f62a702388c713e4bb
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/fpcMotif/ebook-renamer already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 2f30912c02cb6b615434edffd9a0cfcf820588b2025bb4241dc6824ab181340c
[INFO] running `Command { std: "docker" "start" "-a" "2f30912c02cb6b615434edffd9a0cfcf820588b2025bb4241dc6824ab181340c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "2f30912c02cb6b615434edffd9a0cfcf820588b2025bb4241dc6824ab181340c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2f30912c02cb6b615434edffd9a0cfcf820588b2025bb4241dc6824ab181340c", kill_on_drop: false }`
[INFO] [stdout] 2f30912c02cb6b615434edffd9a0cfcf820588b2025bb4241dc6824ab181340c
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 7754f158d5054a59dfaffc81e93aba693565c4ccec1ecce099457853a5385712
[INFO] running `Command { std: "docker" "start" "-a" "7754f158d5054a59dfaffc81e93aba693565c4ccec1ecce099457853a5385712", kill_on_drop: false }`
[INFO] [stderr]    Compiling quote v1.0.42
[INFO] [stderr]    Compiling find-msvc-tools v0.1.5
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling proc-macro2 v1.0.103
[INFO] [stderr]    Compiling smallvec v1.15.1
[INFO] [stderr]    Compiling indexmap v2.12.1
[INFO] [stderr]    Compiling jobserver v0.1.34
[INFO] [stderr]    Compiling mio v1.1.0
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling openssl v0.10.75
[INFO] [stderr]    Compiling signal-hook-registry v1.4.7
[INFO] [stderr]    Compiling tracing-core v0.1.36
[INFO] [stderr]    Compiling http v0.2.12
[INFO] [stderr]    Compiling simd-adler32 v0.3.8
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling parking_lot_core v0.9.12
[INFO] [stderr]    Compiling anstyle-parse v0.2.7
[INFO] [stderr]    Compiling openssl-probe v0.1.6
[INFO] [stderr]    Compiling zstd-safe v7.2.4
[INFO] [stderr]    Compiling anstyle v1.0.13
[INFO] [stderr]    Compiling colorchoice v1.0.4
[INFO] [stderr]    Compiling tokio v1.48.0
[INFO] [stderr]    Compiling signal-hook v0.3.18
[INFO] [stderr]    Compiling miniz_oxide v0.8.9
[INFO] [stderr]    Compiling regex-automata v0.4.13
[INFO] [stderr]    Compiling anstream v0.6.21
[INFO] [stderr]    Compiling parking_lot v0.12.5
[INFO] [stderr]    Compiling cc v1.2.46
[INFO] [stderr]    Compiling tracing v0.1.44
[INFO] [stderr]    Compiling signal-hook-mio v0.2.5
[INFO] [stderr]    Compiling syn v2.0.110
[INFO] [stderr]    Compiling http-body v0.4.6
[INFO] [stderr]    Compiling convert_case v0.7.1
[INFO] [stderr]    Compiling inout v0.1.4
[INFO] [stderr]    Compiling socket2 v0.5.10
[INFO] [stderr]    Compiling futures-channel v0.3.31
[INFO] [stderr]    Compiling rustix v1.1.2
[INFO] [stderr]    Compiling serde_json v1.0.145
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]    Compiling unicode-width v0.2.0
[INFO] [stderr]    Compiling crc v3.4.0
[INFO] [stderr]    Compiling portable-atomic v1.11.1
[INFO] [stderr]    Compiling time v0.3.44
[INFO] [stderr]    Compiling cipher v0.4.4
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]    Compiling flate2 v1.1.5
[INFO] [stderr]    Compiling hmac v0.12.1
[INFO] [stderr]    Compiling itertools v0.13.0
[INFO] [stderr]    Compiling castaway v0.2.4
[INFO] [stderr]    Compiling encoding_rs v0.8.35
[INFO] [stderr]    Compiling toml_write v0.1.2
[INFO] [stderr]    Compiling winnow v0.7.14
[INFO] [stderr]    Compiling clap_lex v0.7.6
[INFO] [stderr]    Compiling linux-raw-sys v0.11.0
[INFO] [stderr]    Compiling bumpalo v3.19.0
[INFO] [stderr]    Compiling zip v2.4.2
[INFO] [stderr]    Compiling crossterm v0.28.1
[INFO] [stderr]    Compiling clap_builder v4.5.51
[INFO] [stderr]    Compiling compact_str v0.8.1
[INFO] [stderr]    Compiling dirs-sys v0.4.1
[INFO] [stderr]    Compiling zopfli v0.8.3
[INFO] [stderr]    Compiling aes v0.8.4
[INFO] [stderr]    Compiling openssl-sys v0.9.111
[INFO] [stderr]    Compiling zstd-sys v2.0.16+zstd.1.5.7
[INFO] [stderr]    Compiling bzip2-sys v0.1.13+1.0.8
[INFO] [stderr]    Compiling lzma-sys v0.1.20
[INFO] [stderr]    Compiling regex v1.12.2
[INFO] [stderr]    Compiling env_filter v0.1.4
[INFO] [stderr]    Compiling xz2 v0.1.7
[INFO] [stderr]    Compiling unicode-truncate v1.1.0
[INFO] [stderr]    Compiling lzma-rs v0.3.0
[INFO] [stderr]    Compiling nom v7.1.3
[INFO] [stderr]    Compiling chrono v0.4.42
[INFO] [stderr]    Compiling pbkdf2 v0.12.2
[INFO] [stderr]    Compiling console v0.15.11
[INFO] [stderr]    Compiling lru v0.12.5
[INFO] [stderr]    Compiling sha1 v0.10.6
[INFO] [stderr]    Compiling md-5 v0.10.6
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling darling_core v0.20.11
[INFO] [stderr]    Compiling csv-core v0.1.13
[INFO] [stderr]    Compiling constant_time_eq v0.3.1
[INFO] [stderr]    Compiling bzip2 v0.5.2
[INFO] [stderr]    Compiling jiff v0.2.16
[INFO] [stderr]    Compiling ipnet v2.11.0
[INFO] [stderr]    Compiling linked-hash-map v0.5.6
[INFO] [stderr]    Compiling deflate64 v0.1.10
[INFO] [stderr]    Compiling number_prefix v0.4.0
[INFO] [stderr]    Compiling colored v2.2.0
[INFO] [stderr]    Compiling csv v1.4.0
[INFO] [stderr]    Compiling indicatif v0.17.11
[INFO] [stderr]    Compiling dirs v5.0.1
[INFO] [stderr]    Compiling quick-xml v0.31.0
[INFO] [stderr]    Compiling md5 v0.7.0
[INFO] [stderr]    Compiling urlencoding v2.1.3
[INFO] [stderr]    Compiling tokio-util v0.7.17
[INFO] [stderr]    Compiling lopdf v0.33.0
[INFO] [stderr]    Compiling h2 v0.3.27
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling zerovec-derive v0.11.2
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling thiserror-impl v2.0.17
[INFO] [stderr]    Compiling darling_macro v0.20.11
[INFO] [stderr]    Compiling zeroize_derive v1.4.3
[INFO] [stderr]    Compiling darling v0.20.11
[INFO] [stderr]    Compiling derive_more-impl v2.0.1
[INFO] [stderr]    Compiling strum_macros v0.26.4
[INFO] [stderr]    Compiling zeroize v1.8.2
[INFO] [stderr]    Compiling instability v0.3.9
[INFO] [stderr]    Compiling clap_derive v4.5.49
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling env_logger v0.11.8
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling yoke v0.8.1
[INFO] [stderr]    Compiling derive_more v2.0.1
[INFO] [stderr]    Compiling crossterm v0.29.0
[INFO] [stderr]    Compiling zerovec v0.11.5
[INFO] [stderr]    Compiling zerotrie v0.2.3
[INFO] [stderr]    Compiling thiserror v2.0.17
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling tinystr v0.8.2
[INFO] [stderr]    Compiling potential_utf v0.1.4
[INFO] [stderr]    Compiling zstd v0.13.3
[INFO] [stderr]    Compiling icu_collections v2.1.1
[INFO] [stderr]    Compiling icu_locale_core v2.1.1
[INFO] [stderr]    Compiling strum v0.26.3
[INFO] [stderr]    Compiling ratatui v0.29.0
[INFO] [stderr]    Compiling clap v4.5.51
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling icu_provider v2.1.1
[INFO] [stderr]    Compiling icu_normalizer v2.1.1
[INFO] [stderr]    Compiling icu_properties v2.1.2
[INFO] [stderr]    Compiling hyper v0.14.32
[INFO] [stderr]    Compiling serde_spanned v0.6.9
[INFO] [stderr]    Compiling toml_datetime v0.6.11
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling toml_edit v0.22.27
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling url v2.5.7
[INFO] [stderr]    Compiling hyper-tls v0.5.0
[INFO] [stderr]    Compiling reqwest v0.11.27
[INFO] [stderr]    Compiling toml v0.8.23
[INFO] [stderr]    Compiling ebook_renamer v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 00s
[INFO] running `Command { std: "docker" "inspect" "7754f158d5054a59dfaffc81e93aba693565c4ccec1ecce099457853a5385712", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7754f158d5054a59dfaffc81e93aba693565c4ccec1ecce099457853a5385712", kill_on_drop: false }`
[INFO] [stdout] 7754f158d5054a59dfaffc81e93aba693565c4ccec1ecce099457853a5385712
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 4bcabe17086b49a4adee848155af8aaa4205eafd905e454bd91299655a11f82f
[INFO] running `Command { std: "docker" "start" "-a" "4bcabe17086b49a4adee848155af8aaa4205eafd905e454bd91299655a11f82f", kill_on_drop: false }`
[INFO] [stderr]    Compiling rustix v1.1.2
[INFO] [stderr]    Compiling crossterm v0.29.0
[INFO] [stderr]    Compiling tempfile v3.23.0
[INFO] [stderr]    Compiling ebook_renamer v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::io::Write`
[INFO] [stdout]    --> src/metadata.rs:434:9
[INFO] [stdout]     |
[INFO] [stdout] 434 |     use std::io::Write;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 8.81s
[INFO] running `Command { std: "docker" "inspect" "4bcabe17086b49a4adee848155af8aaa4205eafd905e454bd91299655a11f82f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "4bcabe17086b49a4adee848155af8aaa4205eafd905e454bd91299655a11f82f", kill_on_drop: false }`
[INFO] [stdout] 4bcabe17086b49a4adee848155af8aaa4205eafd905e454bd91299655a11f82f
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 466f70ab9e48a6a509c19421a5c8ab907cf67e5f7cddc06b08cd2d66b2277070
[INFO] running `Command { std: "docker" "start" "-a" "466f70ab9e48a6a509c19421a5c8ab907cf67e5f7cddc06b08cd2d66b2277070", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `std::io::Write`
[INFO] [stderr]    --> src/metadata.rs:434:9
[INFO] [stderr]     |
[INFO] [stderr] 434 |     use std::io::Write;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `ebook_renamer` (bin "ebook_renamer" test) generated 1 warning (run `cargo fix --bin "ebook_renamer" -p ebook_renamer --tests` to apply 1 suggestion)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.27s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/ebook_renamer-e80446a2e3d1219b)
[INFO] [stdout] 
[INFO] [stdout] running 227 tests
[INFO] [stdout] test cli::tests::test_custom_extensions_with_dots ... ok
[INFO] [stdout] test cli::tests::test_custom_extensions ... ok
[INFO] [stdout] test cli::tests::test_default_extensions ... ok
[INFO] [stdout] test cloud::tests::test_detect_box ... ok
[INFO] [stdout] test cloud::tests::test_detect_dropbox ... ok
[INFO] [stdout] test cloud::tests::test_detect_icloud_drive ... ok
[INFO] [stdout] test cloud::tests::test_detect_google_drive ... ok
[INFO] [stdout] test cloud::tests::test_detect_macos_dropbox ... ok
[INFO] [stdout] test cloud::tests::test_detect_macos_google_drive ... ok
[INFO] [stdout] test cloud::tests::test_detect_mega ... ok
[INFO] [stdout] test cloud::tests::test_detect_nextcloud ... ok
[INFO] [stdout] test cloud::tests::test_detect_pcloud ... ok
[INFO] [stdout] test cloud::tests::test_not_cloud_storage ... ok
[INFO] [stdout] test config::tests::test_config_custom_values ... ok
[INFO] [stdout] test config::tests::test_config_default ... ok
[INFO] [stdout] test config::tests::test_default_dir_tilde_expansion ... ok
[INFO] [stdout] test download_recovery::tests::test_clean_filename ... ok
[INFO] [stdout] test duplicates::tests::test_detect_duplicates_empty_list ... ok
[INFO] [stdout] test download_recovery::tests::test_recover_downloads_empty_dir ... ok
[INFO] [stdout] test download_recovery::tests::test_recover_downloads_does_not_overwrite_existing_file ... ok
[INFO] [stdout] test duplicates::tests::test_detect_duplicates_txt_included ... ok
[INFO] [stdout] test download_recovery::tests::test_recover_downloads_no_auto_cleanup ... ok
[INFO] [stdout] test download_recovery::tests::test_recover_downloads_with_crdownload ... ok
[INFO] [stdout] test duplicates::tests::test_detect_duplicates_by_hash ... ok
[INFO] [stdout] test duplicates::tests::test_detect_duplicates_by_name_when_skip_hash ... ok
[INFO] [stdout] test duplicates::tests::test_detect_duplicates_epub_included ... ok
[INFO] [stdout] test duplicates::tests::test_detect_duplicates_failed_download_excluded ... ok
[INFO] [stdout] test duplicates::tests::test_detect_duplicates_mobi_excluded ... ok
[INFO] [stdout] test duplicates::tests::test_detect_duplicates_same_size_different_content ... ok
[INFO] [stdout] test duplicates::tests::test_detect_duplicates_single_file ... ok
[INFO] [stdout] test duplicates::tests::test_detect_duplicates_skip_hash ... ok
[INFO] [stdout] test duplicates::tests::test_select_file_to_keep_combined_priority ... ok
[INFO] [stdout] test duplicates::tests::test_detect_duplicates_different_sizes ... ok
[INFO] [stdout] test duplicates::tests::test_detect_duplicates_too_small_excluded ... ok
[INFO] [stdout] test duplicates::tests::test_detect_duplicates_three_way_duplicate ... ok
[INFO] [stdout] test duplicates::tests::test_select_file_to_keep_newest ... ok
[INFO] [stdout] test duplicates::tests::test_select_file_to_keep_same_depth_different_time ... ok
[INFO] [stdout] test config::tests::test_config_load_and_save ... ok
[INFO] [stdout] test download_recovery::tests::test_recover_downloads_with_folder ... ok
[INFO] [stdout] test json_output::tests::test_deep_nested_paths ... ok
[INFO] [stdout] test json_output::tests::test_duplicate_group_with_single_file_not_included ... ok
[INFO] [stdout] test duplicates::tests::test_select_file_to_keep_shortest_path ... ok
[INFO] [stdout] test duplicates::tests::test_detect_duplicates_uppercase_extension_included ... ok
[INFO] [stdout] test json_output::tests::test_duplicate_group_deletes_sorted ... ok
[INFO] [stdout] test duplicates::tests::test_select_file_to_keep_normalized ... ok
[INFO] [stdout] test duplicates::tests::test_multiple_duplicate_groups ... ok
[INFO] [stdout] test duplicates::tests::test_detect_name_variants ... ok
[INFO] [stdout] test json_output::tests::test_from_results ... ok
[INFO] [stdout] test json_output::tests::test_json_contains_all_fields ... ok
[INFO] [stdout] test json_output::tests::test_duplicate_groups_sorted_by_keep ... ok
[INFO] [stdout] test json_output::tests::test_json_pretty_print ... ok
[INFO] [stdout] test json_output::tests::test_empty_operations ... ok
[INFO] [stdout] test json_output::tests::test_files_without_new_name_not_included ... ok
[INFO] [stdout] test json_output::tests::test_large_number_of_operations ... ok
[INFO] [stdout] test json_output::tests::test_undo_log_generate_undo_script ... ok
[INFO] [stdout] test json_output::tests::test_undo_log_multiple_operations ... ok
[INFO] [stdout] test json_output::tests::test_relative_paths ... ok
[INFO] [stdout] test json_output::tests::test_operations_output_json_serialization ... ok
[INFO] [stdout] test json_output::tests::test_renames_sorted_by_from ... ok
[INFO] [stdout] test json_output::tests::test_small_deletes_sorted_by_path ... ok
[INFO] [stdout] test json_output::tests::test_special_characters_in_paths ... ok
[INFO] [stdout] test json_output::tests::test_todo_items_sorted_by_category_then_file ... ok
[INFO] [stdout] test json_output::tests::test_undo_log_add_deleted_duplicate ... ok
[INFO] [stdout] test json_output::tests::test_undo_log_add_deleted_small ... ok
[INFO] [stdout] test json_output::tests::test_undo_log_add_rename ... ok
[INFO] [stdout] test json_output::tests::test_undo_log_empty_script ... ok
[INFO] [stdout] test json_output::tests::test_undo_log_shell_escape_special_chars ... ok
[INFO] [stdout] test json_output::tests::test_undo_log_new ... ok
[INFO] [stdout] test json_output::tests::test_undo_log_to_json ... ok
[INFO] [stdout] test json_output::tests::test_unicode_in_paths ... ok
[INFO] [stdout] test metadata::tests::test_metadata_with_values ... ok
[INFO] [stdout] test metadata::tests::test_year_extraction ... ok
[INFO] [stdout] test metadata::tests::test_metadata_default ... ok
[INFO] [stdout] test json_output::tests::test_undo_log_write_and_read ... ok
[INFO] [stdout] test normalizer::tests::test_clean_orphaned_brackets ... ok
[INFO] [stdout] test normalizer::tests::test_clean_underscores ... ok
[INFO] [stdout] test duplicates::tests::test_strip_variant_suffix_edge_cases ... ok
[INFO] [stdout] test duplicates::tests::test_strip_variant_suffix ... ok
[INFO] [stdout] test normalizer::tests::test_comprehensive_all_metadata ... ok
[INFO] [stdout] test normalizer::tests::test_clean_parentheticals_with_publisher ... ok
[INFO] [stdout] test normalizer::tests::test_clean_parentheticals_standalone ... ok
[INFO] [stdout] test normalizer::tests::test_clean_title_comprehensive_sources ... ok
[INFO] [stdout] test normalizer::tests::test_colon_separator ... ok
[INFO] [stdout] test metadata::tests::test_arxiv_id_detection ... ok
[INFO] [stdout] test normalizer::tests::test_edition_detection_2nd ... ok
[INFO] [stdout] test normalizer::tests::test_edition_11th ... ok
[INFO] [stdout] test normalizer::tests::test_cjk_author_detection ... ok
[INFO] [stdout] test normalizer::tests::test_annas_archive_variants ... ok
[INFO] [stdout] test normalizer::tests::test_generate_filename_edition_only ... ok
[INFO] [stdout] test normalizer::tests::test_generate_filename_no_author ... ok
[INFO] [stdout] test normalizer::tests::test_generate_filename_with_edition ... ok
[INFO] [stdout] test normalizer::tests::test_generate_filename_with_series ... ok
[INFO] [stdout] test normalizer::tests::test_generate_filename_with_series_and_edition ... ok
[INFO] [stdout] test normalizer::tests::test_generate_filename_with_volume ... ok
[INFO] [stdout] test normalizer::tests::test_generate_new_filename_with_all_fields ... ok
[INFO] [stdout] test normalizer::tests::test_generate_new_filename_without_year ... ok
[INFO] [stdout] test normalizer::tests::test_extract_year_edge_cases ... ok
[INFO] [stdout] test normalizer::tests::test_crdownload_extension ... ok
[INFO] [stdout] test normalizer::tests::test_arabic_author ... ok
[INFO] [stdout] test normalizer::tests::test_auth_marker_handling ... ok
[INFO] [stdout] test normalizer::tests::test_download_extension ... ok
[INFO] [stdout] test normalizer::tests::test_cyrillic_author ... ok
[INFO] [stdout] test normalizer::tests::test_edition_detection_3rd_ed ... ok
[INFO] [stdout] test normalizer::tests::test_double_dash_separator ... ok
[INFO] [stdout] test normalizer::tests::test_empty_filename ... ok
[INFO] [stdout] test normalizer::tests::test_mixed_brackets ... ok
[INFO] [stdout] test normalizer::tests::test_deadly_decision_beijing ... ok
[INFO] [stdout] test normalizer::tests::test_epub_extension ... ok
[INFO] [stdout] test normalizer::tests::test_eds_marker_handling ... ok
[INFO] [stdout] test normalizer::tests::test_graduate_texts_series_removal ... ok
[INFO] [stdout] test normalizer::tests::test_edition_1st ... ok
[INFO] [stdout] test normalizer::tests::test_japanese_title ... ok
[INFO] [stdout] test normalizer::tests::test_london_math_society_series ... ok
[INFO] [stdout] test normalizer::tests::test_korean_title ... ok
[INFO] [stdout] test normalizer::tests::test_non_publisher_not_detected ... ok
[INFO] [stdout] test normalizer::tests::test_numeric_not_author ... ok
[INFO] [stdout] test normalizer::tests::test_only_brackets ... ok
[INFO] [stdout] test normalizer::tests::test_hash_pattern_detection ... ok
[INFO] [stdout] test normalizer::tests::test_mixed_language_title ... ok
[INFO] [stdout] test normalizer::tests::test_kashiwara ... ok
[INFO] [stdout] test normalizer::tests::test_nested_brackets_and_parens ... ok
[INFO] [stdout] test normalizer::tests::test_lecture_notes_removal ... ok
[INFO] [stdout] test normalizer::tests::test_publisher_keywords_detection ... ok
[INFO] [stdout] test normalizer::tests::test_duplicate_marker_removal ... ok
[INFO] [stdout] test normalizer::tests::test_nested_publisher_removal ... ok
[INFO] [stdout] test normalizer::tests::test_clean_noise_sources_comprehensive ... ok
[INFO] [stdout] test normalizer::tests::test_multiple_years_rightmost ... ok
[INFO] [stdout] test normalizer::tests::test_multi_author_with_commas ... ok
[INFO] [stdout] test normalizer::tests::test_multiple_dashes_in_title ... ok
[INFO] [stdout] test normalizer::tests::test_mani_mehra_wavelets ... ok
[INFO] [stdout] test normalizer::tests::test_short_string_not_author ... ok
[INFO] [stdout] test normalizer::tests::test_series_extraction_csam_parentheses ... ok
[INFO] [stdout] test normalizer::tests::test_parse_simple_filename ... ok
[INFO] [stdout] test normalizer::tests::test_no_extension ... ok
[INFO] [stdout] test normalizer::tests::test_parse_with_series_prefix ... ok
[INFO] [stdout] test normalizer::tests::test_part_to_volume_conversion ... ok
[INFO] [stdout] test normalizer::tests::test_series_gsm ... ok
[INFO] [stdout] test normalizer::tests::test_isbn_removal ... ok
[INFO] [stdout] test normalizer::tests::test_series_lmsln ... ok
[INFO] [stdout] test normalizer::tests::test_parse_author_before_title_with_publisher ... ok
[INFO] [stdout] test normalizer::tests::test_translator_not_author ... ok
[INFO] [stdout] test normalizer::tests::test_trailing_dash_cleanup ... ok
[INFO] [stdout] test normalizer::tests::test_unclosed_parenthesis ... ok
[INFO] [stdout] test normalizer::tests::test_quantum_cohomology ... ok
[INFO] [stdout] test normalizer::tests::test_parse_with_year ... ok
[INFO] [stdout] test normalizer::tests::test_parse_z_library_variant ... ok
[INFO] [stdout] test normalizer::tests::test_series_extraction_gtm ... ok
[INFO] [stdout] test normalizer::tests::test_semicolon_separator ... ok
[INFO] [stdout] test normalizer::tests::test_special_characters_in_title ... ok
[INFO] [stdout] test normalizer::tests::test_single_word_comma_removal ... ok
[INFO] [stdout] test normalizer::tests::test_whitespace_only_title ... ok
[INFO] [stdout] test normalizer::tests::test_series_pm ... ok
[INFO] [stdout] test renamer::tests::test_execute_renames_handles_simple_cycle ... ok
[INFO] [stdout] test normalizer::tests::test_title_only_no_author ... ok
[INFO] [stdout] test renamer::tests::test_resolve_rename_collisions_avoids_overwriting_existing_file ... ok
[INFO] [stdout] test scanner::tests::test_scanner_creates_correct_file_info ... ok
[INFO] [stdout] test scanner::tests::test_scanner_detects_crdownload_files ... ok
[INFO] [stdout] test scanner::tests::test_scanner_detects_download_files ... ok
[INFO] [stdout] test scanner::tests::test_scanner_detects_small_files ... ok
[INFO] [stdout] test renamer::tests::test_resolve_rename_collisions_adds_suffixes ... ok
[INFO] [stdout] test scanner::tests::test_scanner_detects_tar_gz ... ok
[INFO] [stdout] test normalizer::tests::test_systems_of_microdifferential_with_hash ... ok
[INFO] [stdout] test scanner::tests::test_scanner_epub_small_file_detection ... ok
[INFO] [stdout] test scanner::tests::test_scanner_empty_directory ... ok
[INFO] [stdout] test scanner::tests::test_scanner_file_as_root_path ... ok
[INFO] [stdout] test scanner::tests::test_scanner_failed_download_not_flagged_as_small ... ok
[INFO] [stdout] test scanner::tests::test_scanner_file_size_recorded ... ok
[INFO] [stdout] test scanner::tests::test_scanner_handles_crdownload_file_extension ... ok
[INFO] [stdout] test scanner::tests::test_scanner_file_without_extension ... ok
[INFO] [stdout] test scanner::tests::test_scanner_handles_download_file_extension ... ok
[INFO] [stdout] test scanner::tests::test_scanner_invalid_directory ... ok
[INFO] [stdout] test scanner::tests::test_scanner_handles_nested_directories ... ok
[INFO] [stdout] test scanner::tests::test_scanner_max_depth_limit ... ok
[INFO] [stdout] test scanner::tests::test_scanner_multiple_file_types ... ok
[INFO] [stdout] test scanner::tests::test_scanner_mobi_not_checked_for_small_size ... ok
[INFO] [stdout] test scanner::tests::test_scanner_preserves_relative_path_structure ... ok
[INFO] [stdout] test scanner::tests::test_scanner_size_threshold_1023_bytes ... ok
[INFO] [stdout] test scanner::tests::test_scanner_size_threshold_exactly_1kb ... ok
[INFO] [stdout] test scanner::tests::test_scanner_txt_not_checked_for_small_size ... ok
[INFO] [stdout] test scanner::tests::test_scanner_unicode_filename ... ok
[INFO] [stdout] test scanner::tests::test_scanner_skips_hidden_files ... ok
[INFO] [stdout] test scanner::tests::test_scanner_respects_depth ... ok
[INFO] [stdout] test security::tests::test_safe_delete_nonexistent ... ok
[INFO] [stdout] test security::tests::test_validate_max_depth ... ok
[INFO] [stdout] test todo::tests::test_add_failed_download ... ok
[INFO] [stdout] test security::tests::test_sanitize_filename_valid ... ok
[INFO] [stdout] test todo::tests::test_add_file_issue_invalid_extension ... ok
[INFO] [stdout] test todo::tests::test_add_file_issue_too_small ... ok
[INFO] [stdout] test todo::tests::test_analyze_file_integrity_corrupted_epub ... ok
[INFO] [stdout] test todo::tests::test_add_file_issue_read_error ... ok
[INFO] [stdout] test security::tests::test_shell_escape ... ok
[INFO] [stdout] test todo::tests::test_analyze_file_integrity_non_pdf_file ... ok
[INFO] [stdout] test todo::tests::test_analyze_file_integrity_corrupted_pdf ... ok
[INFO] [stdout] test todo::tests::test_analyze_file_integrity_skips_too_small ... ok
[INFO] [stdout] test todo::tests::test_analyze_file_integrity_valid_epub ... ok
[INFO] [stdout] test todo::tests::test_analyze_file_integrity_skips_failed_download ... ok
[INFO] [stdout] test todo::tests::test_extract_items_from_empty_md ... ok
[INFO] [stdout] test todo::tests::test_extract_items_from_md ... ok
[INFO] [stdout] test normalizer::tests::test_title_only_filename ... ok
[INFO] [stdout] test todo::tests::test_extract_items_mixed_checkbox_states ... ok
[INFO] [stdout] test todo::tests::test_duplicate_item_prevention ... ok
[INFO] [stdout] test todo::tests::test_analyze_file_integrity_valid_pdf ... ok
[INFO] [stdout] test normalizer::tests::test_tools_for_pde ... ok
[INFO] [stdout] test todo::tests::test_extract_items_skips_generic_checklist ... ok
[INFO] [stdout] test todo::tests::test_remove_file_from_todo ... ok
[INFO] [stdout] test todo::tests::test_remove_file_case_insensitive ... ok
[INFO] [stdout] test todo::tests::test_special_characters_in_filename ... ok
[INFO] [stdout] test todo::tests::test_todolist_new_and_write ... ok
[INFO] [stdout] test todo::tests::test_unicode_filename_in_todo ... ok
[INFO] [stdout] test todo::tests::test_write_empty_todo_shows_success_message ... ok
[INFO] [stdout] test todo::tests::test_write_generates_sections ... ok
[INFO] [stdout] test todo::tests::test_todolist_with_custom_path ... ok
[INFO] [stdout] test todo::tests::test_todolist_reads_existing_items ... ok
[INFO] [stdout] test todo::tests::test_validate_pdf_header_different_versions ... ok
[INFO] [stdout] test todo::tests::test_validate_pdf_header_too_short ... ok
[INFO] [stdout] test tui::tests::test_ui_render_rich_text ... ok
[INFO] [stdout] test normalizer::tests::test_volume_volume_keyword ... ok
[INFO] [stdout] test normalizer::tests::test_volume_detection ... ok
[INFO] [stdout] test normalizer::tests::test_txt_extension ... ok
[INFO] [stdout] test normalizer::tests::test_wavelets_with_multiple_authors_and_z_library ... ok
[INFO] [stdout] test normalizer::tests::test_very_long_filename ... ok
[INFO] [stdout] test normalizer::tests::test_year_in_title_preserved ... ok
[INFO] [stdout] test normalizer::tests::test_trailing_id_noise_removal ... ok
[INFO] [stdout] test normalizer::tests::test_website_url_removal ... ok
[INFO] [stdout] test normalizer::tests::test_uploaded_by_removal ... ok
[INFO] [stdout] test normalizer::tests::test_unnecessary_info_removal ... ok
[INFO] [stdout] test normalizer::tests::test_strip_generic_series_prefix ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 227 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 1.32s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "466f70ab9e48a6a509c19421a5c8ab907cf67e5f7cddc06b08cd2d66b2277070", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "466f70ab9e48a6a509c19421a5c8ab907cf67e5f7cddc06b08cd2d66b2277070", kill_on_drop: false }`
[INFO] [stdout] 466f70ab9e48a6a509c19421a5c8ab907cf67e5f7cddc06b08cd2d66b2277070
